草庐IT

sql - mysql 查询 - 包含?

全部标签

ruby-on-rails - Has_Many :Through or :finder_sql

我已经确定了我想要的东西,但我似乎无法以Rails设计师正在寻找的方式获得它。基本上,我有(请搁置多元化/等问题):人类关系(parent、后代)我正在尝试获取单亲的所有后代,以及许多后代的单亲(假设每个后代只有一个parent)。我可以在模型中通过以下方式做到这一点:has_one:parent,:through=>:relationships,:foreign_key=>:human_id,:source=>:source_humanhas_many:offsprings,:finder_sql=>'SELECTDISTINCToffsprings.*'+'FROMhumansof

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - 在 Rspec 中用项目符号标记 N+1 查询

我正在尝试使用bulletgem标记N+1并在代码中添加计数器缓存的位置.但是手动执行所有检查N+1查询的操作似乎非常痛苦,所以我尝试使用Bullet和Rspec,使用他们推荐的设置步骤:#config/environments/test.rbconfig.after_initializedoBullet.enable=trueBullet.bullet_logger=trueBullet.raise=true#raiseanerrorifn+1queryoccursend#spec/spec_helper.rbifBullet.enable?config.before(:each)d

ruby-on-rails - 有没有办法检查 Ruby 变量是否包含二进制数据?

我正在使用Ruby2.4和Rails5。我在名为“content”的变量中有文件内容。内容可能包含来自PDF文件、Word文件或HTML文件之类的数据。有什么办法可以判断变量是否包含二进制数据?最后,我想知道这是PDF、MicrosoftOffice还是其他类型的OpenOffice文件。这个答案——Rails:possibletocheckifastringisbinary?--建议我可以检查变量的编码content.encoding它会产生ASCII-8BIT然而,在二进制数据的情况下,我注意到有些情况下存储在变量中的HTML内容也可能返回“ASCII-8BIT”作为content

ruby-on-rails - ActiveRecord:查询未对 STI 子类使用正确的类型条件

我有一组STI子类继承自User基类。我发现在子类定义中的某些条件下,对子类的查询没有正确使用type条件。classUser在开发中加载Rails控制台时,它会按照我的预期进行:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`IN('Admin')但是当点击应用程序(localhost/pow)时,它缺少type条件,我明白了:Admin:SELECT`users`.*FROM`users`但在部署到暂存服务器时不是来自应用程序:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`

ruby - YARD:记录由包含的模块添加的类方法

我正在使用YARD为我的ruby​​gem编写文档.在我的gem中,我有一些代码遵循这种常见的ruby​​模式,其中一个模块包含在一个类中,并且该模块不仅添加了实例方法,还添加了类方法:moduleMoodefself.included(klass)klass.extendClassMethodsendmoduleClassMethodsdefhelloputs"hello"endendendclassFooincludeMooendFoo.hello#=>classmethodruns,printing"hello"默认情况下,YARD将为Foo类生成如下所示的文档:我认为此文档不充

ruby - 如何选择要在 Ruby 中动态包含的模块版本?

我正在编写一个使用fileutils的小型Rub​​y命令行应用程序来自文件操作的标准库。根据用户调用应用程序的方式,我想包括FileUtils,FileUtils::DryRun或FileUtils::Verbose.自include虽然是私有(private)的,但我无法将选择逻辑放入对象的initialize中方法。(这是我的第一个想法,从那时起我就可以将有关用户选择的信息作为参数传递给new。)我想出了两个似乎可行的选项,但我对其中任何一个都不满意:根据用户的选择在应用程序的命名空间中设置一个全局变量,然后在类中执行条件包含:classWorkercaseApp::OPTION

ruby-on-rails - has_many 嵌套表单,其中包含 has_one 嵌套表单

我目前正在尝试为一个模型制作一个表单,该模型具有动态数量的嵌套模型。我正在使用嵌套表单(如RailsCasts197中所述)。让事情变得更加复杂的是,我的每个嵌套模型都有一个与第三个模型的has_one关联,我也想将其添加到表单中。对于任何对过度规范化或不正确方法感到疑惑的人,此示例是我所面临问题的简化版本。实际上,事情稍微复杂一些,这就是我们决定采用的方法。一些示例代码来说明下面的问题:#MODELSclassTestattr_accessible:test_name,:test_description,:questions_attributeshas_many:questionsa

ruby-on-rails - Rails as_json 问题 - 如何有效地包含嵌套对象?

我遇到了一个问题,我正在使用as_json方法,以及如何有效地返回JSON中的对象AND它也是belongs_to对象作为JSON,其中belongs_to对象具有它自己的belongs_to对象。代码可能会更好地解释它。无效的方式警报类classAlert:message)endend消息类defas_json(options={})super(methods:[:timestamp,:num_photos,:first_photo_url,:tag_names],include:{camera:{only:[:id,:name]},position:{only:[:id,:name

ruby - 如何使用 Ruby 1.9 检测字符串是否仅包含拉丁符号?

我需要检测某个字符串是否包含来自非拉丁字母表的符号。数字和特殊符号如-、_、+都可以。我需要知道是否有任何非拉丁符号。例如:"123sdjjsf-4KSD".just_latin?应该返回true。"12333ыц4--sdf".just_latin?应该返回false。 最佳答案 我认为这对你有用:#encoding:UTF-8classStringdefjust_latin?!!self.match(/^[a-zA-Z0-9_\-+]*$/)endendputs"123sdjjsf-4KSD".just_latin?puts"1